<template>
  <div class="departments-container">
    <div class="app-container">
      <!-- 组织架构的内容 -->
      <el-card class="tree-card">
        <!-- 放置结构内容 -->
        <tree-tools :tree-node="company" :is-root="true" @addDepts="addDepts" />
        <!-- 放置一个el-tree -->
        <el-tree
          :data="departs"
          :props="defaultProps"
          :default-expand-all="true"
        >
          <!-- 传入内容 插槽内容 会循环多次 有多少节点 就循环多少次-->
          <!-- 作用域插槽 slot-scope=“obj” 接收传递插槽的数据  data每个节点的数据对象-->
          <tree-tools
            slot-scope="{ data }"
            :tree-node="data"
            @addDepts="addDepts"
            @editDepts-tools="editDepts"
            @delDepts="getDepartments"
          />
          <!-- 上面 getDepartments 这里的意思是删除完成后在重新拉取数据-->
        </el-tree>
      </el-card>
    </div>

    <!-- 放置新增弹层组件 -->
    <add-dept
      ref="addDept"
      :show-dialog.sync="showDialog"
      :tree-node="node"
      @changeDial="test"
      @addDepts="getDepartments"
    />
  </div>
</template>

<script>
import TreeTools from './components/tree-tools'
import { getDepartmentsApi } from '@/api/departments'
import { tranListToTreeData } from '@/utils'
import AddDept from './components/add-dept'

export default {
  components: {
    TreeTools,
    AddDept
  },
  data() {
    return {
      // company: { name: '江苏传智博客教育科技股份有限公司', manager: '负责人' }, // 头部的数据结构
      company: {}, // 就是头部的数据结构
      departs: [],

      defaultProps: {
        lable: 'name' // 表示，从这个属性显示内容
        // children: 'children' // 从这个属性去找子节点
      },
      showDialog: false, // 默认不显示弹层
      node: null // 记录当前点击的node节点
    }
  },
  created() {
    this.getDepartments() // 调用自己的方法
  },
  methods: {
    async getDepartments() {
      const result = await getDepartmentsApi()
      this.company = { name: result.companyName, manager: '负责人', id: '' }
      this.departs = tranListToTreeData(result.depts, '') // 需要将其转化为树形结构
      console.log(result)
    },

    // 监听 tree-tools中触发的点击添加子部门的事件
    // node 是我们当前点击的部门
    addDepts(node) {
      this.showDialog = true // 显示弹层
      this.node = node
    },
    test(value) {
      this.showDialog = value
    },
    editDepts(node) {
      this.showDialog = true // 弹出层
      this.node = node
      // 应该在这里调用获取部门详情的方法
      this.$refs.addDept.getDepartDetail(node.id)
    }
  }
}
</script>

<style>
.tree-card {
  padding: 30px 140px;
  font-size: 14px;
}
</style>
